-
Notifications
You must be signed in to change notification settings - Fork 989
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Package vendor new feature #16073
Package vendor new feature #16073
Conversation
…to compute graph on a repackage dependency
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice! Some minor super minor minor suggestions
Co-authored-by: Rubén Rincón Blanco <git@rinconblanco.es>
@memsharded I must be too late but the docs for these changes weren't available until recently. Looking into them I see that your approach is to remove all dependencies from the graph completely. I'm not sure it's a great idea. Even repackaged binaries may depend on each other; think of a dll that depends on some internal static libraries (which we would like to hide via repackaging) but requires another repackaged dll to run. Maybe a global |
Of course. This is an advanced feature that must be used with lots of care. But it is also the result of a large demand, see the ticket #13171, and how many tickets it has linked. A very popular use case is to distribute final products to other organizations, via Conan packages. Organizations have the need to "repackage" or fully isolate dependencies sometimes. They are already doing it via a more manual process like using a When we fully document it, we will make sure to clarify the risks and the cautions that users must have. Of course there are many cases that it won't be possible, this feature is intended for some particular use cases, and abuse is always possible, but we will try our best to warn against it. Still the users are responsibles, it is not great that many of them have to do a tedious and manual work for something that Conan can provide built-in. |
So it's mainly intended for packaging self-contained applications. It's understandable (due to relative simplicity), but personally I would also like to be able to package (exclude from the graph) specific requirements. Something like def requirements(self):
self.requires("dep/1.0", bundle=True) |
I see what you mean, but what would be exactly the use case of this? Why vendoring only some dependencies, but not others? |
I'd like to bundle an application, but it in turn consists of some modules (dlls). These modules depend on each other. I need to keep these top-level dependencies but hide implementation details (static lib dependencies). I think I'm not alone but of course cannot predict how many users anticipate this feature. |
But what if the DLLs have transitive dependencies themselves, would you also make the |
Actually, I would like to vendor everything except a small set of top-level dlls (that nonetheless depend on each other). The whole application is quite big, bundling everything together and making a new package on any change is impractical e.g. in terms of size (hundreds of megabytes in my case). Fine-grained vendoring would allow updating just one module for end users; I think it's much more convenient. |
Understood. I think this is something that we can consider, lets wait to get more feedback from the feature, some real world usage from more users, and lets take this idea for the following iterations. I am not saying this is impossible, just that better go step by step, learn a bit more about the current proposal and iterate from there. Thanks for the feedback! |
Changelog: Feature: New
vendor=True
package creation and build isolation strategyDocs: conan-io/docs#3756
Close #13171